package co.edu.usbcali.csru.modelo.control;

import co.edu.usbcali.csru.dataaccess.daoFactory.XMLHibernateDaoFactory;
import co.edu.usbcali.csru.dataaccess.sessionFactory.HibernateSessionFactory;
import co.edu.usbcali.csru.exceptions.*;
import co.edu.usbcali.csru.modelo.*;
import co.edu.usbcali.csru.utilities.Utilities;

import java.math.BigDecimal;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Set;


/**
 * interface CuentaLogic
 * @author Zathura Code Generator http://code.google.com/p/zathura
 *
 */
public class CuentaLogic implements ICuentaLogic {
	
	public List<Cuenta> getCuenta() throws Exception {
		List<Cuenta> list = new ArrayList<Cuenta>();

		try {
			list = XMLHibernateDaoFactory.getInstance().getCuentaDAO().findAll();
		} catch (Exception e) {
			throw new ZMessManager().new GettingException(ZMessManager.ALL +
					"Cuenta");
		} finally {
		}

		return list;
	}

	public void saveCuenta(String cueCodCuenta, String estCodigo_Estado,
			String priCodigo_PropietarioInmueble) throws Exception {
		Cuenta entity = null;

		try {
			
			if (estCodigo_Estado == null) {
				throw new ZMessManager().new EmptyFieldException(
						"estCodigo_Estado");
			}

			if ((estCodigo_Estado != null) &&
					(Utilities.checkWordAndCheckWithlength(estCodigo_Estado, 10) == false)) {
				throw new ZMessManager().new NotValidFormatException(
						"estCodigo_Estado");
			}

			if (priCodigo_PropietarioInmueble == null) {
				throw new ZMessManager().new EmptyFieldException(
						"priCodigo_PropietarioInmueble");
			}

			if ((priCodigo_PropietarioInmueble != null) &&
					(Utilities.checkWordAndCheckWithlength(
							priCodigo_PropietarioInmueble, 10) == false)) {
				throw new ZMessManager().new NotValidFormatException(
						"priCodigo_PropietarioInmueble");
			}

			IEstadoLogic logicEstado1 = new EstadoLogic();
			IPropietarioInmuebleLogic logicPropietarioInmueble2 = new PropietarioInmuebleLogic();
			Estado estadoClass = logicEstado1.getEstado(estCodigo_Estado);
			PropietarioInmueble propietarioInmuebleClass = logicPropietarioInmueble2.getPropietarioInmueble(priCodigo_PropietarioInmueble);

			if (estadoClass == null) {
				throw new ZMessManager().new ForeignException("estado");
			}

			if (propietarioInmuebleClass == null) {
				throw new ZMessManager().new ForeignException(
						"propietarioInmueble");
			}

			entity = new Cuenta();
			entity.setCueCodCuenta(cueCodCuenta);
			entity.setEstado(estadoClass);
			entity.setPropietarioInmueble(propietarioInmuebleClass);
			HibernateSessionFactory.beginTransaction();
			XMLHibernateDaoFactory.getInstance().getCuentaDAO().save(entity);
			HibernateSessionFactory.commit();
		} catch (Exception e) {
			HibernateSessionFactory.rollback();
			throw e;
		} finally {
			HibernateSessionFactory.closeSession();
		}
	}

	public void deleteCuenta(String cueCodCuenta) throws Exception {
		Cuenta entity = null;

		if (cueCodCuenta == null) {
			throw new ZMessManager().new EmptyFieldException("cueCodCuenta");
		}

		List<Factura> facturas = null;
		entity = getCuenta(cueCodCuenta);

		if (entity == null) {
			throw new ZMessManager().new EmptyFieldException("Cuenta");
		}

		try {
			facturas = XMLHibernateDaoFactory.getInstance().getFacturaDAO()
			.findByProperty("cuenta.cueCodCuenta",
					cueCodCuenta);

			if (Utilities.validationsList(facturas) == true) {
				throw new ZMessManager().new DeletingException("facturas");
			}

			HibernateSessionFactory.beginTransaction();
			XMLHibernateDaoFactory.getInstance().getCuentaDAO().delete(entity);
			HibernateSessionFactory.commit();
		} catch (Exception e) {
			HibernateSessionFactory.rollback();
			throw e;
		} finally {
			HibernateSessionFactory.closeSession();
		}
	}

	public void updateCuenta(String cueCodCuenta, String estCodigo_Estado,
			String priCodigo_PropietarioInmueble) throws Exception {
		Cuenta entity = null;

		try {
			if (cueCodCuenta == null) {
				throw new ZMessManager().new EmptyFieldException("cueCodCuenta");
			}

			if ((cueCodCuenta != null) &&
					(Utilities.checkWordAndCheckWithlength(cueCodCuenta, 10) == false)) {
				throw new ZMessManager().new NotValidFormatException(
						"cueCodCuenta");
			}

			if (estCodigo_Estado == null) {
				throw new ZMessManager().new EmptyFieldException(
						"estCodigo_Estado");
			}

			if ((estCodigo_Estado != null) &&
					(Utilities.checkWordAndCheckWithlength(estCodigo_Estado, 10) == false)) {
				throw new ZMessManager().new NotValidFormatException(
						"estCodigo_Estado");
			}

			if (priCodigo_PropietarioInmueble == null) {
				throw new ZMessManager().new EmptyFieldException(
						"priCodigo_PropietarioInmueble");
			}

			if ((priCodigo_PropietarioInmueble != null) &&
					(Utilities.checkWordAndCheckWithlength(
							priCodigo_PropietarioInmueble, 10) == false)) {
				throw new ZMessManager().new NotValidFormatException(
						"priCodigo_PropietarioInmueble");
			}

			IEstadoLogic logicEstado1 = new EstadoLogic();

			IPropietarioInmuebleLogic logicPropietarioInmueble2 = new PropietarioInmuebleLogic();
			Estado estadoClass = logicEstado1.getEstado(estCodigo_Estado);
			PropietarioInmueble propietarioInmuebleClass = logicPropietarioInmueble2.getPropietarioInmueble(priCodigo_PropietarioInmueble);

			if (estadoClass == null) {
				throw new ZMessManager().new ForeignException("estado");
			}

			if (propietarioInmuebleClass == null) {
				throw new ZMessManager().new ForeignException(
						"propietarioInmueble");
			}

			entity = getCuenta(cueCodCuenta);

			if (entity == null) {
				throw new ZMessManager(ZMessManager.ENTITY_NOENTITYTOUPDATE);
			}

			entity.setCueCodCuenta(cueCodCuenta);
			entity.setEstado(estadoClass);
			entity.setPropietarioInmueble(propietarioInmuebleClass);
			HibernateSessionFactory.beginTransaction();
			XMLHibernateDaoFactory.getInstance().getCuentaDAO().update(entity);
			HibernateSessionFactory.commit();
		} catch (Exception e) {
			HibernateSessionFactory.rollback();
			throw e;
		} finally {
			HibernateSessionFactory.closeSession();
		}
	}

	public Cuenta getCuenta(String cueCodCuenta) throws Exception {
		Cuenta entity = null;

		try {
			entity = XMLHibernateDaoFactory.getInstance().getCuentaDAO()
			.findById(cueCodCuenta);
		} catch (Exception e) {
			throw new ZMessManager().new FindingException("Cuenta");
		} finally {
		}

		return entity;
	}

	public List<Cuenta> findPageCuenta(String sortColumnName,
			boolean sortAscending, int startRow, int maxResults)
			throws Exception {
		List<Cuenta> entity = null;

		try {
			entity = XMLHibernateDaoFactory.getInstance().getCuentaDAO()
			.findPageCuenta(sortColumnName,
					sortAscending, startRow, maxResults);
		} catch (Exception e) {
			throw new ZMessManager().new FindingException("Cuenta");
		} finally {
		}

		return entity;
	}

	public Long findTotalNumberCuenta() throws Exception {
		Long entity = null;

		try {
			entity = XMLHibernateDaoFactory.getInstance().getCuentaDAO()
			.findTotalNumberCuenta();
		} catch (Exception e) {
			throw new ZMessManager().new FindingException("Cuenta Count");
		} finally {
		}

		return entity;
	}

	/**
	 *
	 * @param varibles
	 *            este arreglo debera tener:
	 *
	 * [0] = String variable = (String) varibles[i]; representa como se llama la
	 * variable en el pojo
	 *
	 * [1] = Boolean booVariable = (Boolean) varibles[i + 1]; representa si el
	 * valor necesita o no ''(comillas simples)usado para campos de tipo string
	 *
	 * [2] = Object value = varibles[i + 2]; representa el valor que se va a
	 * buscar en la BD
	 *
	 * [3] = String comparator = (String) varibles[i + 3]; representa que tipo
	 * de busqueda voy a hacer.., ejemplo: where nombre=william o where nombre<>william,
	 * en este campo iria el tipo de comparador que quiero si es = o <>
	 *
	 * Se itera de 4 en 4..., entonces 4 registros del arreglo representan 1
	 * busqueda en un campo, si se ponen mas pues el continuara buscando en lo
	 * que se le ingresen en los otros 4
	 *
	 *
	 * @param variablesBetween
	 *
	 * la diferencia son estas dos posiciones
	 *
	 * [0] = String variable = (String) varibles[j]; la variable ne la BD que va
	 * a ser buscada en un rango
	 *
	 * [1] = Object value = varibles[j + 1]; valor 1 para buscar en un rango
	 *
	 * [2] = Object value2 = varibles[j + 2]; valor 2 para buscar en un rango
	 * ejempolo: a > 1 and a < 5 --> 1 seria value y 5 seria value2
	 *
	 * [3] = String comparator1 = (String) varibles[j + 3]; comparador 1
	 * ejemplo: a comparator1 1 and a < 5
	 *
	 * [4] = String comparator2 = (String) varibles[j + 4]; comparador 2
	 * ejemplo: a comparador1>1  and a comparador2<5  (el original: a > 1 and a <
	 * 5) *
	 * @param variablesBetweenDates(en
	 *            este caso solo para mysql)
	 *  [0] = String variable = (String) varibles[k]; el nombre de la variable que hace referencia a
	 *            una fecha
	 *
	 * [1] = Object object1 = varibles[k + 2]; fecha 1 a comparar(deben ser
	 * dates)
	 *
	 * [2] = Object object2 = varibles[k + 3]; fecha 2 a comparar(deben ser
	 * dates)
	 *
	 * esto hace un between entre las dos fechas.
	 *
	 * @return lista con los objetos que se necesiten
	 * @throws Exception
	 */
	public List<Cuenta> findByCriteria(Object[] variables,
			Object[] variablesBetween, Object[] variablesBetweenDates)
			throws Exception {
		List<Cuenta> list = new ArrayList<Cuenta>();
		String where = new String();
		String tempWhere = new String();

		if (variables != null) {
			for (int i = 0; i < variables.length; i++) {
				if ((variables[i] != null) && (variables[i + 1] != null) &&
						(variables[i + 2] != null) &&
						(variables[i + 3] != null)) {
					String variable = (String) variables[i];
					Boolean booVariable = (Boolean) variables[i + 1];
					Object value = variables[i + 2];
					String comparator = (String) variables[i + 3];

					if (booVariable.booleanValue()) {
						tempWhere = (tempWhere.length() == 0)
						? ("(model." + variable + " " + comparator + " \'" +
								value + "\' )")
								: (tempWhere + " AND (model." + variable + " " +
										comparator + " \'" + value + "\' )");
					} else {
						tempWhere = (tempWhere.length() == 0)
						? ("(model." + variable + " " + comparator + " " +
								value + " )")
								: (tempWhere + " AND (model." + variable + " " +
										comparator + " " + value + " )");
					}
				}

				i = i + 3;
			}
		}

		if (variablesBetween != null) {
			for (int j = 0; j < variablesBetween.length; j++) {
				if ((variablesBetween[j] != null) &&
						(variablesBetween[j + 1] != null) &&
						(variablesBetween[j + 2] != null) &&
						(variablesBetween[j + 3] != null) &&
						(variablesBetween[j + 4] != null)) {
					String variable = (String) variablesBetween[j];
					Object value = variablesBetween[j + 1];
					Object value2 = variablesBetween[j + 2];
					String comparator1 = (String) variablesBetween[j + 3];
					String comparator2 = (String) variablesBetween[j + 4];
					tempWhere = (tempWhere.length() == 0)
					? ("(" + value + " " + comparator1 + " " + variable +
							" and " + variable + " " + comparator2 + " " + value2 +
							" )")
							: (tempWhere + " AND (" + value + " " + comparator1 +
									" " + variable + " and " + variable + " " +
									comparator2 + " " + value2 + " )");
				}

				j = j + 4;
			}
		}

		if (variablesBetweenDates != null) {
			for (int k = 0; k < variablesBetweenDates.length; k++) {
				if ((variablesBetweenDates[k] != null) &&
						(variablesBetweenDates[k + 1] != null) &&
						(variablesBetweenDates[k + 2] != null)) {
					String variable = (String) variablesBetweenDates[k];
					Object object1 = variablesBetweenDates[k + 1];
					Object object2 = variablesBetweenDates[k + 2];
					String value = null;
					String value2 = null;

					try {
						Date date1 = (Date) object1;
						Date date2 = (Date) object2;
						value = Utilities.formatDateWithoutTimeInAStringForBetweenWhere(date1);
						value2 = Utilities.formatDateWithoutTimeInAStringForBetweenWhere(date2);
					} catch (Exception e) {
						list = null;
						throw e;
					}

					tempWhere = (tempWhere.length() == 0)
					? ("(model." + variable + " between \'" + value +
							"\' and \'" + value2 + "\')")
							: (tempWhere + " AND (model." + variable +
									" between \'" + value + "\' and \'" + value2 + "\')");
				}

				k = k + 2;
			}
		}

		if (tempWhere.length() == 0) {
			where = null;
		} else {
			where = "(" + tempWhere + ")";
		}

		try {
			list = XMLHibernateDaoFactory.getInstance().getCuentaDAO()
			.findByCriteria(where);
		} catch (Exception e) {
			throw new Exception(e.getMessage());
		} finally {
		}

		return list;
	}

	public String crearLogin(String primerNombre, String primerApellido) throws Exception {

		String login = primerNombre + primerApellido;

		return login;
	}

	public String generarPasswordCuenta() throws Exception {

		char[] s = createABC();
		String password = "";

		do {
			int azar = (int) (Math.random() * 25) + 1;
			int azarNum = (int) (Math.random() * 9) + 1;
			password = password.concat(Character.toString(s[azar]));
			password = password.concat(Integer.toString(azarNum));
		} while (password.length() < 8);

		return password;
	}

	public char[] createABC() throws Exception {

		char[] s = new char[26];

		for (int i = 0; i < 26; i++) {

			s[i] = (char) ('a' + i);
		}
		return s;
	}
}
